import axios from 'axios';
import { ElMessage } from 'element-plus'
import useUserStore from "@/store/modules/user";

// 配置新建一个 axios 实例
const service = axios.create({
    baseURL: import.meta.env.VITE_APP_BASE_API,
    timeout: 50000,
    headers: { 'Content-Type': 'application/json' ,
        'Access-Control-Allow-Origin':'*'},
});

service.interceptors.request.use(
    (config) => {
        //请求拦截器携带Token数据
        let userStore = useUserStore()

        if (userStore.token) {
            config.headers.token = userStore.token
        }
        return config
    },
    (error) => {
        return Promise.reject(error)
    },
)

service.interceptors.response.use(
    (response) => {
        if (response.status === 200) {
            return Promise.resolve(response.data)
        } else {
            return Promise.reject(response.data)
        }
    },
    (error) => {
        let message = ''
        let status = error.response.status
        switch (status) {
            // 401: 未登录
            // 未登录则跳转登录页面，并携带当前页面的路径
            // 在登录成功后返回当前页面，这一步需要在登录页操作。
            case 401:
                message = '未登录'
                break
            // 403 token过期
            // 登录过期对用户进行提示
            // 清除本地token和清空vuex中token对象
            // 跳转登录页面
            case 403:
                message = '登录过期，请重新登录'
                break
            case 404:
                message = '网络请求不存在'
                break
            case 500:
                message = '服务器出现问题'
                break
            default:
                message = error.response.data.message
                break
        }
        ElMessage({
            type: 'error',
            message,
        })
        return Promise.reject(error)
    },
)
export default service;